﻿using System;
using CAD.DAO;
using System.Data;
using RN.Entidades;
using System.Collections.Generic;

namespace RN.Componentes
{
    public class CArea
    {
        #region DMLS
        public static bool Insertar(Area objProxy)
        {
            ValidationException x = new ValidationException();

            if (string.IsNullOrEmpty(objProxy.Nombre))
                x.AgregarError("Ingrese el nombre del area");

            if (x.Cantidad > 0)
                throw x;

            DAOArea daoProxy = new DAOArea();

            return daoProxy.Insertar(objProxy.Nombre) > 0;
        }
        public static bool ActualizarArea(Area objProxy)
        {
            ValidationException x = new ValidationException();
            if (objProxy.Codigo <= 0)
                x.AgregarError("Ingrese el código");

            if (string.IsNullOrEmpty(objProxy.Nombre))
                x.AgregarError("Ingrese el nombre del area");

            if (x.Cantidad > 0)
                throw x;

            DAOArea daoProxy = new DAOArea();

            return daoProxy.Actualizar(objProxy.Codigo, objProxy.Nombre);
        }
        
        public static bool EliminarArea(int codigo)
        {
            ValidationException x = new ValidationException();

            if (codigo <= 0)
                x.AgregarError("Ingrese el código");

            if (x.Cantidad > 0)
                throw x;

            DAOArea daoProxy = new DAOArea();

            return daoProxy.Eliminar(codigo);
        }
        #endregion

        #region Selects
        public static List<Area> Traer()
        {
            DAOArea daoProxy = new DAOArea();

            DataSet dtsProxy = daoProxy.TraerArea();

            return CargarLista(dtsProxy.Tables[0]);
        }

        public static List<Area> TraerXId(int codigo)
        {
            DAOArea daoProxy = new DAOArea();

            DataSet dtsProxy = daoProxy.TraerAreaXId(codigo);

            return CargarLista(dtsProxy.Tables[0]);
        }

        public static List<Area> TraerXNombre(string nombre)
        {
            DAOArea daoProxy = new DAOArea();

            DataSet dtsProxy = daoProxy.TraerAreaXNombre(nombre);

            return CargarLista(dtsProxy.Tables[0]);
        }
        #endregion

        #region Metodos Privados
        private static List<Area> CargarLista(DataTable tabla)
        {
            List<Area> lstProxy = new List<Area>();

            foreach (DataRow fila in tabla.Rows)
            {
                lstProxy.Add(Cargar(fila));
            }
            return lstProxy;
        }

        private static Area Cargar(DataRow fila)
        {
            Area objProxy = new Area();
            objProxy.Codigo = Convert.ToInt32(fila["Iareas_id"]);
            objProxy.Nombre = fila["snombre"].ToString();
            return objProxy;
        }
        #endregion
    }
}
